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Search Criteria 

Fill in at least one field. Fill more to narrow your search. 
Need high speed? Try Fast Search. 
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// construct the simple search conditions 
Attribute attrl = new Attribute (CatRefldAttributelnfo, Operator.equal, "123"); 
Qno j Attribute attr2 = new Attribute (Colourttributelnfo, Operator.equal, "red"); 
^ | Attribute attr3 = new Attribute (ManufactureAttributelnfo, Operator.equal, "Sears"); 
Attribute attr4 = new 

Attribute (CatRefldAttributelnfo ) Operator I equal,DescRefldAttributelnfo ) ); 

// compose composite search conditions 
804 ■{ Predicate pi = new Predicate (Operatorand, (attrl, attr2) ); 
Predicate p2 = new Predicate (Operatorand, {p1, attr3, attr4} ); 

r II execute the query 
OA/; I Query q = new Query ( ) 

° uo 1 q.setResultSet ({ CatRefldAttributelnfo, ...)) // result set contains catalog entryld 

q.setPredicate (p2); 
808 result = q.execute ( ) 
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public void MCQuery( ) throws Exception { 
Debug.setLocalTest(true); 

System.out.println(" ****************** Merchant Centre 
900 — CatalogQuery MCQuery = new CatalogQuery( ); 901 



902 



r II Result set 

MCQuery.addResLiltSetlnfo(new Result(CatEntryldentifierAttributelnfo.getSingleton( )( ))); 

MCQuery.addResiiltSetlnfojnew Result(StorelnvQuantityAttributelnfo.getSingleton( )( ))); 

MCQuery.addResultSetlnfo(new Result(CatEntDescShortDescAttributelnfo.getSingleton( )( ))); 

MCQuery.addResultSetlnfojnew Result(CatEntDescNameAttributelnfo.getSingleton( )( ))); 

MCQuery.addResultSetInfo(new Result(CatEntryTypeAttributelnfo.getSingleton( )( ))); 
v MCQuery.setDistinctQualifier(true); — ^_ ^4 
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// Predicate set 
// Part I 

Predicate p11 = new Predicate ( ); — ^ 908a 
pllsetOperator (Operator.or); 

Attribute a111 = new Attribute (CatGrpDescNameAttributelnfo.getSingleton( ), OperatorJeftlike, 
"CATEGORY X"); 
a111.setUppercaseQualifier(true); 
pltaddOperand (a111); 

Attribute a112 = new Attribute (CatGrpDescNameAttributelnfo.getSingleton( ), OperatorJeftlike, 
"CATEGORY10" 

a112.setUppercaseQualifier(true); 
pltaddOperand (a112); 
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Predicate p12 = new Predicate ( ); — ^ 908a 
p12.setOperator (Operator.and); 

p12.add0perand (new Attribute (ListPriceAttributelnfo.getSingleton( ), Operator.gt, "0.0")); 
p12.addOperand (new Attribute (StorelnvQuantityAttributelnfo.getSingleton( ), Operator.gt, "0.0")); 
p12.addOperand (new Attribute (lnventoryQuantityMeasureAttributelnfo.getSingleton( ), Operator.isnull)); 
p12.addOperand (p11); 

Predicate p13 = new Predicate ( ); ~ 908a 
p13.setOperator (Operator.and); 

p13.addOperand (new Attribute (ListPriceAttributelnfo.getSingleton( ), Operator.gt, "0.0")); 
p13.addOperand (new Attribute (StorelnvQuantityAttributelnfo.getSingleton( ), Operator.gt, "0.0")); 
p13.addOperand (new Attribute (lnventoryQuantityMeasureAttributelnfo.getSingleton( ), Operatorisi 
Attribute a13 = new Attribute (CatGrpDescNameAttributelnfo.getSingleton( ), Operator.leflike, 
"CATEGORY5"); 
a13.setUppercaseQualifier(true); 
p13.addOperand (a13); 

Predicate p14 = new Predicate ( ); ~ 908a 
p14.setOperator (Operator.or); 
p14.add0perand (p12); 
p14.addOperand (p13); 
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// Part II 

r Predicate p2 = new Predicate ( ); 908b 
p21.setOperator (Operator.or); 

Attribute a211 = new Attribute (CatGrpDescNameAttributelnfo.getSingleton( ), OperatorJeftlike, 
"CATEGORY Z"); 
a211.setUppercaseQualifier(true); 
p21.add0perand (a211); 

Attribute a212 = new Attribute (CatGrpDescNameAttributelnfo.getSingleton( ), OperatorJeftlike, 
"CATEG0RY9" 

a212.set(JppercaseQualifier(true); 
p21.add0perand (a212); 
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Predicate p22 = new Predicate ( ); ^ 908b 
p22.set0perator (Operatorand); 

p22.addOperand (new Attribute (ListPriceAttributelnfo.getSingleton( ), Operator.gt, "0.0")); 
p22.addOperand (new Attribute (StorelnvQuantityAttributelnfo.getSingleton( ), Operator.gt, "0.0")); 
p22.addOperand (new Attribute (lnventoryQuantityMeasureAttributelnfo.getSingleton( ), Operatorisi 
p22.addOperand (p21); 

Predicate p23 = new Predicate ( ); 908b 
p23.setOperator (Operator.and); 

p23.addOperand (new Attribute (ListPriceAttributelnfo.getSingleton( ), Operator.gt, "0.0")); 

p23.addOperand (new Attribute (StorelnvQuantityAttributelnfo.getSingleton( ), Operator.gt, "0.0")); 

p23.addOperand (new Attribute (lnventoryQuantityMeasureAttributelnfo.getSingleton( ), Operatorisnull)); 

Attribute a23 = new Attribute (CatGrpDescNameAttributelnfo.getSingleton( ), Operator.leflike, 

"CATEGORY4"); 

a23.setUppercaseQualifier(true); 

p23.addOperand (a23); 
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Predicate p24 = new Predicate ( ); 908b 
p24.setOperator (Operator.or); 
p24.addOperand (p22); 
p24.addOperand (p23); 



System.out.println(p24.toString( )); 
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// Part IV ■- Join 

Predicate p4 = new Predicate ( ); — ^—912 
p4.setOperator (Operator.and); 
p4.add0perand (p14); 
p4.add0perand (p24); 

p4.add0perand (new Attribute (StoreCEntStoreldentifierAttributelnfo.getSingleton( ), ^ 
Operator.eq, "2")); 

p4.add0perand (new Attribute (UsersldentifierAttributelnfo.getSingleton( ), Operator.eq, 
"1001")); 

//p4.addOperand (p33); 
MCQuery.setPredicate(p4); — 916 
// Join 

System.out.println("Auto Join : "); 
' DintRelationships( ); 



// Resolve source tables 
MCQuery.resolveSourceTables( ); — » — 918 

// ORDER, GROUP and HAVING set 
MCQuery.addResultOrder(CatEntryldentifierAttributelnfo.getSingleton(), 
Operator.desc); -u-920 

System.out.println("MC Query : "); 
System.out.println(MCQuery.toString( )); 

com.ibm.commerce.base.objects.Cursor cursor = new 
com.ibm.commerce.base.objects.Cursor( ); ^ 
java.util.Vector v = MCQuery.execute(cursor); ~r~^ LL 
SystemMprintlnfMC Query first 10 Result: ") 
System,out.println(v); 

cursor.increment( ); q«« 
v = MCQuery.execute(cursor); — ^ 
System.out.println("MC Query next 10 Result: "); 
System.println(v); 

} 
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public void setPredicate(Predicate aPredicate) throws Exception { 

Predicate additionalP = additionalPredicate( ); — ^ 924 
if (additionalP != null) { 

Predicate p = new Predicate ); 

p.setOperator(Operator.and); 

p.addOperand(aPredicate); 

p.addOperand(additionalP); 

setTableJointPredicate(p); 

else 

setTableJointPredicate(aPredicate); 



private void setTablejointPredicate(Predicate aPredicate) throws Exception 

Predicate jointP = resolveJointPredicate(aPredicate); 
if (jointP != null) { 
Predicate p = new Predicate ); 
p.setOperator(Operator.and); 
p.addOperand(aPredicate); 
p.addOperand(jointP); 



supersetPredicate(p); 
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else 



super.setPredicate(aPredicate); 
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Table C 




TA, TB 


TO, TE 
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Table D 




TA, TC 
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